草庐IT

C++ 泛型 vector

全部标签

c# - 为什么 C# 出的泛型类型参数会违反协变?

我不清楚为什么以下代码片段不是协变的?publicinterfaceIResourceColl:IEnumerablewhereT:IResource{intCount{get;}Tthis[intindex]{get;}boolTryGetValue(stringSUID,outTobj);//Errorhere?}Error1Invalidvariance:Thetypeparameter'T'mustbeinvariantlyvalidon'IResourceColl.TryGetValue(string,outT)'.'T'iscovariant.我的界面只在输出位置使用模板参

c# - 为什么 VS 警告我 typeof(T) 永远不是泛型方法中提供的类型,其中类型参数仅限于实现 T?

我希望问题是正确的,所以让我们举个例子。想象以下通用方法:publicabstractclassBase:IDisposable{publicstaticIEnumerableGetList()whereT:Base{//ToensureTinheritsfromBase.if(typeof(T)isBase)thrownewNotSupportedException();//...}}根据MSDN关键字where将类型参数T限制为Base类型或从此类继承。[...]awhereclausecanincludeabaseclassconstraint,whichstatesthatat

c# - 在 C# 中将泛型对象添加到泛型列表

我有相关部分看起来像的类classC{voidMethod(SomeClassobj){list.Add(obj);}Listlist=newList();}我应该如何定义列表以便类编译?我想要一个List>类型的列表,这是SomeClass的对象列表每个对象都可以有任何类型参数。Java?构造允许这样做;什么是C#等价物?如果不存在这样的事情,是否有合适的解决方法?(List可以,但非常丑陋。) 最佳答案 我认为您不能在C#中执行此操作...您必须将类型参数添加到类中:classC{voidMethod(SomeClassobj)

c# - 类型 'T' 必须是不可为 null 的值类型才能将其用作泛型类型或方法 'T' 中的参数 'System.Nullable<T>'

为什么我在以下代码中会收到此错误?voidMain(){int?a=1;int?b=AddOne(1);a.Dump();}staticNullableAddOne(Nullablenullable){returnApplyFunction(nullable,(intx)=>x+1);}staticNullableApplyFunction(Nullablenullable,Funcfunction){if(nullable.HasValue){Tunwrapped=nullable.Value;TResultresult=function(unwrapped);returnnewNu

c# - 如何调用基于封闭泛型的方法重载?

假设我有三种方法:voidFoo(MemoryStreamv){Console.WriteLine("MemoryStream");}voidFoo(Streamv){Console.WriteLine("Stream");}voidFoo(objectv){Console.WriteLine("object");}我调用方法Foo传递开放泛型类型的第一个参数:voidBar(){Foo(default(T));//justtoshowthescenario//default(T)ornewT()doesn'tmakeadifference,nullisirrelevanthere}我

C# Generic List of Multiple Types 泛型列表

这是我的问题的抽象和简化:我有一套玩具和这些玩具对应的盒子。我希望用户能够指定盒子可以容纳的最大类型的玩具:publicclassBox{}然后在Box类中我想要一个通用的玩具列表,但是盒子中包含的每个玩具都有一个通用类型:publicclassBox{publicList=newList();publicboolWhatever;[memberfunctions,constructors...][ThememberfunctionswilldependonT]}Toys类将如下所示:publicclassToywhereT:struct//Tisanytype{publicList=

c# - 泛型:强制转换和值类型,为什么这是非法的?

为什么这是编译时错误?publicTCastToCastMe(TSourcei){return(TCastTo)i;}错误:Cannotconverttype'TSource'to'TCastTo'为什么这是一个运行时错误?publicTCastToCastMe(TSourcei){return(TCastTo)(object)i;}inta=4;longb=CastMe(a);//InvalidCastException//thiscontrivedexampleworksintaa=4;intbb=CastMe(aa);//thisalsoworks,theproblemislim

c# - 在 C# 中使用泛型时装箱

我有以下简单的C#代码:privateStackm_stack=newStack();publicvoidAdd(Tobj)whereT:Person{m_stack.Push(obj);}这将产生以下IL代码:.methodpublichidebysiginstancevoidAdd(!!Tobj)cilmanaged{//Codesize20(0x14).maxstack8IL_0000:nopIL_0001:ldarg.0IL_0002:ldfldclass[System]System.Collections.Generic.Stack`1ConsoleApplication1.

C# 泛型 - 如何返回特定类型?

也许我做错了。我有一堆派生自“模型”类的类,这是一个具有大量通用属性和方法的基类。我希望它们都实现一组功能:publicabstractvoidCreate();publicabstractTRead(GuidID);//然后我在像“Appointment”这样的子类中实现它:publicoverrideTRead(GuidID){varappt=db.Appointments.First(a=>a.AppointmentID.Equals(ID));varappointment=newAppointment(){DateEnd=appt.dateEnd.GetValueOrDefau

c# - C# 中的多态性、重载和泛型

classPoly{publicstaticvoidWriteVal(inti){System.Console.Write("{0}\n",i);}publicstaticvoidWriteVal(strings){System.Console.Write("{0}\n",s);}}classGenWriter{publicstaticvoidWrite(Tx){Poly.WriteVal(x);}}为什么在C#中不接受无辜的(对于C++程序员)方法Write?您可以看到编译器尝试将参数类型T与具体重载相匹配before实例化:错误3Thebestoverloadedmethodmat